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BROADCAST COMMUNICATION SYSTEM 
WITH DYNAMIC CLIENT-GROUP MEMBERSHIPS 



A broadcast communication system may include a host that 
transmits messages to a number of client devices. An example 
of a broadcast communication system is a digital cable system 
that transmits television signals over a cable line from a 
head end to set-top appliances connected to customers' 
televisions. The head end may transmit general system 
signals, such as basic cable channels, to all set-top 
appliances in the system. The head end may also send client - 
specific signals, including pay-per-view programs or 
authorizations that are addressed to the set-top appliances of 
customers that ordered the pay-per-view programs. 

At any given time there may be many messages being 
transmitted over the system, many of which may not be intended 
for all of the client devices. At a certain traffic level and 
demand for particular messages, individually addressing 
client -specif ic messages may be cumbersome and time-consuming 
for the host processor and reduce the available bandwidth in 
the communication link. It may therefore be desirable to 
assign clients to groups and address messages to the group 
rather than the individual clients, and to update the group 
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membership records at the head end and client devices as they 
are added, modified, or deleted from the system. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a schematic diagram of a communication system 
5 capable of dynamically grouping client devices according to an 
embodiment . 

Figure 2 is a schematic representation of a message 
format including group addressing according to an embodiment. 

Figure 3 is a flowchart illustrating an operation for 
Q 10 updating group memberships according to an embodiment. 
Lg Figure 4 is a flowchart illustrating an operation for 

03 receiving group directed messages according to an embodiment. 

Kj DETAILED DESCRIPTION 

H Figure 1 illustrates a communication system 100 according 

r — ■» 

^ 15 to an embodiment that may dynamically assign client devices to 
groups in the system. The system may include a host 102 that 
may broadcast messages to client devices 104, 105 in the 
system. The messages may be addressed as general call 
messages intended for all client devices in the system, 
20 client-specific messages intended for particular client 

devices, and/or group-specific messages intended for client 
devices belonging to particular groups in the system. 
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The host 102 may create, modify, and remove groups from 
the system. A group may include one or more member client 
devices, and a client device may be a member of none, one, or 
many groups. The groups may be dynamic, with group 
memberships changing over time. 

The host 102 may transmit messages to client devices over 
a communication link 106. A system server 108 may format 
messages and transmit them from a transmitter 110. The system 
server 108 may format the messages into packets 200 that 
include a header portion 2 02 and a payload portion 2 04 as 
shown in Figure 2. The header portion 202 may include a 
client identifier for a client specific message, or a group 
identifier for a group-specific message. The payload portion 
2 04 may include content such as audio and video signals for 
television programs and movies, data for electronic program 
guides and advertisements, software modules for video games, 
and system management messages. The system management 
messages may include, for example, authorization information, 
billing information, and diagnostic and maintenance software 
modules for servicing the client device 104, 105. 

In an embodiment, the header portion 202 may include a 
number of fields. These fields may include, for example, a 
protocol version field 210, a target type field 212, a target 
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field 214, a message identifier field 216, a message type 
field 218, and a payload size field 220. 

The value in the protocol version field 210 may identify 
the version of the protocol used to describe the message. 

The value in the target type field 212 may be a Boolean 
flag which identifies the identifier in the target field as 
either a client identifier, e.g., value =0, or a group 
identifier, e.g., value = 1. The value in the target field 
214 identifies the intended target of the message, which may 
be a particular client or a group of clients. 

The host 102 may transmit messages multiple times, e.g., 
in a message carousel, to capture client devices that are off 
or otherwise unavailable at the time of the first 
transmission. The value in the message identifier field 216 
may identify a message as a new message from the host 102, or 
a repeated message. 

The value in the message type field 218 may indicate the 
type, or purpose, of the message. These types may include, 
for example, test messages, software download schedule 
information, and alert messages. 

The value in the payload size field 220 may indicate the 
number of bytes in the payload portion 204. The payload size 
value may be compared to an actual count of the bytes received 
in the payload as an error checking measure . 
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The host 102 may include a client profile database 112. 
A client device may have an individual client identifier. 
That client identifier may be associated with profile 
information for that client device in the client profile 
5 database 112. The profile information may include information 
about a particular client device and customer. This 
information may include, for example, services and/or products 
the client device is authorized to receive, orders and 
subscriptions placed by the customer, geographic and contact 

10 information, and demographic information. The demographic 

information may include, for example, the customer's household 
income, number and age of children, interests, service and 
program preferences, number and type of consumer appliances, 
and historical information, such as payment records, and past 

15 subscriptions and orders placed by the customer. 

Figure 3 illustrates an operation 300 for updating 
dynamic groups in the system according to an embodiment . The 
flow of the operation 3 00 is exemplary, and blocks in the 
flowchart may be skipped or performed in different order 

20 according to alternate embodiments. 

A group management server 12 0 may include hardware and 
software for creating new groups and modifying existing groups 
based on information in the client profile database 112. The 
group management server 12 0 may create a new group from 



-5- 



Q10 



m 



Docket No.: ^^p9/357001/P10034 

information in the client profile database 112 in block 302. 
The group may include member clients that share a common 
criterion. For example, a group may be created for the client 
devices of customers that have ordered a particular service, 
for example, a premium channel service in a digital cable 
system. Another group may be created for the client devices 
of customers that have ordered a particular product, for 
example, a video game software module. Another group may be 
created for customers that belong to certain demographic or 
geographic groups which may be targeted by certain 
advertisers. For example, households that report children 
between the ages of three and nine years may be included in a 
group that is targeted to receive an electronic catalog of age 
appropriate toys. 

Each group may have a group identifier. The client 
identifiers of member clients in the group may be linked or 
otherwise associated with that group identifier in a client- 
group database 122. As shown in Table 1, a client device may 
belong to more than one group. 



Client ID 


Group ID 


0x00000007 


0x00001000 


0x00000007 


0x04000000 


0x00000010 


0x04000000 



20 



Table 1 
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The group management server 120 may compile a general 
membership file from the contents of the client-group database 
122 in block 304 for transmission to the client devices 104, 
105. The general membership file may be a data structure 
5 organized as, for example, a file, a database, or a table. 

The client identifiers of member clients may be mapped to the 
corresponding group identifier in the general membership file. 
The compiled general membership file may be transmitted to the 
client devices in block 306. 

10 The general membership file may be relatively large, and 

the host may compress the general membership file prior to 
transmission to conserve the processing resources of the 
client devices. The general membership file may also be 
encoded with error checking data. 

15 The client device 105 may include a receiver connected to 

the communication link 106 for receiving the general 
membership file and messages from the host 102, a receiver 
controller 132 to inspect transmissions from the host, and an 
identifier memory 134. The identifier memory 134 may include 

20 a client identifier file 136 to store the individual client 
identifier of the client device and an internal membership 
file 138 to store the group identifier (s) of the group (s) in 
which the client device 105 is currently a member. 
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Client devices in the system may receive the general 
membership file in block 3 08 and use it to update their 
internal membership files in block 310. When the client 
device 105 receives the general membership file, the receiver 
5 controller 132 may inspect the file for group identifiers the 
client identifier is associated with and compare those group 
identifiers to the group identifiers currently stored in the 
identifier memory 134. Based on this comparison, the receiver 
controller 132 may store new group identifiers that are 
p10 associated with the client identifier in the identifier memory 
S 1 134. The receiver controller may also delete group 

W identifiers that are no longer associated with the client 

Jff identifier from the identifier memory 134. Thus, the receiver 

!\ controller 132 may update the internal membership file 134 to 

=fs15 agree with the group-client associations contained in the last 
n general membership file transmitted. 

The host 102 may transmit the general membership file 
repeatedly to account for client devices that were not 
available for reception at the time the general membership 
20 file was first transmitted. Such unavailable client devices 
may include those that were off or out of reception range at 
the time of the first transmission. Unavailable client 
devices may also include devices that were busy handling 
operations having a higher priority than receiving and 
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handling the general membership file. For example, if a 
customer is using the client device 105, for example, to 
decode a video or voice signal, the client device 105 may 
ignore the general membership file and wait for the next 
5 t ransmi s s ion . 

To reduce the number of unavailable client devices, the 
host may transmit the general membership file at off-peak 
times, when many client devices may be idle and better able to 
utilize their processor resources to handle such system 
q10 functions. For example, in a digital cable system, the 
Si general membership file may be transmitted when most customers 

m 

yi are not watching television, for example 3 a.m. In a wireless 

zi phone/PDA system, the general membership file may be 

transmitted every several hours in carousel fashion. 
J{J15 The group management server 120 may modify the groups in 

□ the client-group database 122 over time in block 314 in 

response to changed circumstances. For example, a new group 

may be generated for a new service provided by the host 102. 

An existing group may be deleted when a service campaign ends. 
20 New members may be added to a group, for example, new 

subscribers to a service. Existing members may be removed 

from a group, for example, subscribers who cancel or are 

delinquent in payment. 



-9- 



Docket No. 




59/357001/ 



P10034 



When the group management server 120 modifies the groups 
in the client-group database 122, the operation 300 may return 
to block 304 and compile a new, updated general membership 
file. The updated general membership file may be transmitted 
upon being compiled or at a next scheduled transmission time. 

Figure 4 illustrates an operation 400 for updating 
dynamic groups in the system according to an embodiment . The 
flow of the operation 400 is exemplary, and blocks in the 
flowchart may be skipped or performed in different order 
according to alternate embodiments. 

When the client device 105 receives a message in block 
4 02, the receiver controller 132 may inspect the target type 
field 212 and target field 214 of the message in block 404 and 
compare it to the client identifier or. the group identifier (s) 
in the identifier memory in block 406. If the identifier in 
the header portion does not match any identifier in the client 
device's identifier memory 134 in state 408, the message may 
be discarded in block 410. If the identifier in the header 
portion matches an identifier in the identifier memory 134, 
the message may be passed on to a processor 140 in block 412. 

The processor 140 may include a microprocessor for 
executing instructions stored in a memory 142 and processing 
data. The processor may include a signal processor, such as a 
digital signal processor (DSP) for processing compressed and 
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encoded digital signals, for example, digital video and audio 
signals. The processor 140 may extract the contents of the 
payload portion 2 04 in block 414 and store the payload in the 
memory 142 and/or prepare the payload for output to an output 
device 144. The output device 144 may include, for example, a 
television, a liquid crystal display (LCD) or cathode ray tube 
(CRT) display screen, and/or a speaker. 
EXAMPLES : 

In an embodiment, a digital cable system may include 
subscription-based groups. When a customer subscribes to a 
premium channel service, the group management server 12 0 at 
the host 102 may update the client-group database 122 to 
include the customer's client device identifier in the premium 
channel group. At the next broadcast of the general 
membership file to the client devices 104, 105 in the system, 
the customer's client device 105 may receive and inspect the 
general membership file for group identifiers associated with 
the client device's individual client identifier. Finding an 
association between the client identifier and the premium 
channel group identifier, the receiver controller 132 may 
update the identifier memory 134 to include the premium 
channel group identifier. 

After the update, the receiver controller 132 of the 
client device 105 inspects the headers of messages transmitted 
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by the host 102, and passes messages that include premium 
channel group identifier in the header 202 to the processor 
140. The processor 140 may extract the payload and output the 
digital video and audio signals of the premium channels to the 
customer's television 144. 

The customer may cancel the subscription to the premium 
channel service. If so, the group management server 120 may 
remove the customer's client device identifier from the 
premium channel group in the client-group database 122. In 
the next general membership file transmission, the receiver 
controller 132 at the client device 105 may inspect the 
general membership file for an association between the premium 
channel group identifier in the internal membership file 138 
and the client identifier in the client identifier file 136. 
Finding no association, the receiver controller 132 may update 
the internal membership file 138 by deleting the premium 
channel group identifier from the membership file 138. 

In another embodiment, the digital cable system may 
include geographic -based groups. For example, a supermarket 
may request that the host transmit an electronic advertisement 
for a sale campaign to system customers in the vicinity of the 
supermarket. The group management server 12 0 may query the 
client profile database 112 for clients in a geographical 
area, defined, for example, by zip code(s). The group 
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management server may generate a sales campaign group 
identifier and link it to the client identifiers returned from 
the zip code query. An updated general membership file may be 
transmitted to the client devices in the next transmission 
cycle, and the member client devices updated to include the 
sales campaign group identifier in their identifier memories. 
The system server 108 may format the electronic advertisement 
into a message (s) with the sales campaign group identifier in 
the header 202. The message (s) may be transmitted and 
received by members of the group. The electronic 
advertisement may be displayed on the customer's television 
144 automatically or when selected by the customer. 

When the sale campaign ends, the group management server 
120 may delete the group from the client-group database 122 
and transmit an updated general membership file. Upon 
receiving the updated general membership file, the members of 
the sale campaign group may delete the sale campaign group 
identifier from their identifier memories. 

In another embodiment, the system may be a wireless 
network and the client devices may be hand-held PDA units. 
The PDA units may include Global Positioning System (GPS) 
modules. The PDA may periodically transmit their current 
position to the system host. The system host 102 may update 
the client profile database 112 with this geographic 
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information. An advertiser, for example a department store 
having a weekend sale, may use this geographic information to 
target customers in the vicinity of the department store. A 
group may be created and the general membership file 



customers traveling in the vicinity of the department store. 
The group may then be deleted at the end of the sale weekend. 

In an embodiment, the communication system 100 with 
dynamic client grouping may have a head end- to- set -top 
appliance organization as in many cable, digital cable, and 
television satellite dish systems. In an alternative 
embodiment, the communication system 100 may have a central 
station-to-client organization as in many wireless telephone, 
wireless internet, wireless personal digital assistant (PDA) 



The communication link 106 may be a transmission line 
such as co-axial cable, fiber optic, plain old telephone 
system (POTS) , or digital subscriber line, or it may be a 
wireless RF signal transmitted via satellite or base stations 
to a receiver, such as a dish, or a transceiver, such as those 
used in wireless hand-held devices. The communication link 
106 may include a combination of such communication media. 

A number of embodiments have been described. 
Nevertheless, it will be understood that various modifications 
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systems . 
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may be made without departing 
invention. Accordingly, other 
of the following claims. 
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from the spirit and scope of the 
embodiments are within the scope 
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